Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Change lookup of '.runtimeconfig.json' as relative to cwd #542

Closed
wants to merge 1 commit into from

Conversation

loklaan
Copy link

@loklaan loklaan commented Jul 30, 2019

👋 Elllooooo, this is my first time contributing to firebase stuff.

Description

The lookup for .runtimeconfig.json has an unexpected behaviour, which makes it only ever work if the .runtimeconfig.json file is at the root of your repo/project (next to node_modules).

This breaks local-emulation and deployed projects that are setup with monorepos, yarn's pnp, or bundled fn's.

Directly addresses: #476, #264, #438, #328, #172

Relates to: firebase/firebase-tools#653

Notes

Is this a breaking change?

I'm inclined to say no, and it is just a minor change. But one could argue that folks now rely on this static ../../../.runtimeconfig.json lookup. Counter-counter argument would be to say that these kinds of consumers are liking relying on CLOUD_RUNTIME_CONFIG anyway. 🤷‍♂️

@loklaan loklaan requested a review from thechenky as a code owner July 30, 2019 09:46
@loklaan loklaan force-pushed the sane-runtime-config-lookup branch 2 times, most recently from e8db93b to 7ac0653 Compare July 30, 2019 10:29
@thechenky thechenky requested review from kevinajian and mbleigh July 30, 2019 16:11
@mbleigh
Copy link
Contributor

mbleigh commented Jul 30, 2019

As written this is definitely behavior-changing, and there are instances where cwd() is not going to be the same as the package root directory.

I think the behavior probably ought to be to make your lookup additive, if CLOUD_RUNTIME_CONFIG is not present and the static lookup path does not exist. As-is, I worry that this would break people in unexpected ways.

@loklaan
Copy link
Author

loklaan commented Jul 31, 2019

You're right @mbleigh, and good approach. I've implemented it in the recent push.

It is now supporting the existing behaviour, then if those locations don't exist it will then traverse up from the cwd until it finds a .runtimeconfig.json file (or it doesn't, that's fine too).

@mbleigh
Copy link
Contributor

mbleigh commented Feb 4, 2021

Hey @loklaan this issue is...well, really old now. But if you're interested in updating the PR to resolve merge conflicts and keep the "don't break existing behavior", I'm open to merging.

Sorry for letting this one slip through the cracks!

@loklaan loklaan force-pushed the sane-runtime-config-lookup branch from 8e4baa2 to 6cc350b Compare February 4, 2021 23:47
@loklaan
Copy link
Author

loklaan commented Feb 4, 2021

@mbleigh Oh brilliant I forgot about this - thanks for coming back to it!

Since I opened this PR, it looks like the behaviour has changed from:

  1. Use path from ENV variable
  2. Or, use a fixed path (../../../.runtimeconfig.json)

To:

  1. Use path from ENV variable (same)
  2. Or, use a fixed path (${process.env.PWD}/.runtimeconfig.json) (changed)

This is great, although even after this long I still think that there should be a 3rd lookup attempt on parent directories above the working directory. So, I've updated the PR to support the current behaviours, and fallback to parent lookup using sindresorhus/find-up

@loklaan
Copy link
Author

loklaan commented Feb 9, 2021

Ah looks like the node ^8 test fails.. For everyone? Let's ignore that I suppose.

Pinging you @mbleigh so, fingers crossed, this won't get buried again haha

@mbleigh
Copy link
Contributor

mbleigh commented Feb 9, 2021

Thanks for the update. I hate to be a pain when you already were willing to overlook a year-plus gap, but we are trying to maintain or reduce the number of dependencies in the Firebase CLI. Do you think you could implement the same logic without find-up?

@loklaan
Copy link
Author

loklaan commented Feb 9, 2021

Haha all good, I get it @mbleigh .

Ahh I'm sure we could inline it, plucking the code from find-up itself?

I want to point out that find-up is quite light though (including transitive deps), so including it might ok?

📦  find-up@5.0.0
=== Tarball Contents ===
1.1kB license
1.9kB index.js
917B  package.json
4.0kB readme.md
3.8kB index.d.ts
=== Tarball Details ===
name:          find-up
version:       5.0.0
filename:      find-up-5.0.0.tgz
package size:  3.8 kB
unpacked size: 11.8 kB
shasum:        4c92819ecb7083561e4f4a240a86be5198f536fc
integrity:     sha512-78/PXT1wlLLDg[...]vNtrJRiW6nGng==
total files:   5

@mbleigh
Copy link
Contributor

mbleigh commented Feb 10, 2021

It's less about the size of the implementation and more about exposing us to code that changes without us knowing it (there are scary enough examples of that in NPM's history). FWIW here's some similar code we wrote for the Firebase CLI to find firebase.json in an ancestor directory tree. That could be a good base.

@loklaan loklaan force-pushed the sane-runtime-config-lookup branch from 6cc350b to 0453d61 Compare February 12, 2021 01:44
@loklaan
Copy link
Author

loklaan commented Feb 12, 2021

@mbleigh I've removed the find-up dep, replacing it with a similar function. 👍

Copy link
Contributor

@mbleigh mbleigh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh goodness, I had this review queued up months ago and forgot to hit submit 😦

* Like fs.existsSync, but fails softly.
* @param path A path to check exists.
*/
export function existsSync(path): boolean | void {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's rename this to something like safeExistsSync to indicate the behavioral difference from standard existsSync.

* @param options The options change findUp behaviour.
*/
export function findUpSync(
fileName,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: filename is the initialism I'm familiar with.

@loklaan
Copy link
Author

loklaan commented Jul 9, 2021

Hi! Thanks for getting around to it. Last couple (er, many) months have been rough for many all round.

I'll be dropping this PR though 😞 as I don't have the involvement in Firebase projects anymore, and am spending time elsewhere. I encourage anyone that has subscribed to pick it up, if you want!

Thanks @mbleigh for the reviews, and sorry if this feels at all like I've wasted your time. I've definitely appreciated your thoughtfulness here, as well as your long term commitment to the Firebase team. All the best!

@loklaan loklaan closed this Jul 9, 2021
@mbleigh
Copy link
Contributor

mbleigh commented Jul 9, 2021

👋 Love having folks in the community contribute, sorry this got lost in the shuffle. Have a good one!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants